草庐IT

c++ - std::transform 的泛化

全部标签

c++ - 可视化图像数据的调试器

是否有调试器(如果可能的话免费)可以在调试session期间可视化图像缓冲区。像这样的东西:我在断点处停止。然后我选择一个图像缓冲区,给出数据的说明-RBG、CMYK、8位、float等等。我看到了一张由数据制成的图像(或保存的图像)。 最佳答案 如果您使用gdb调试您的程序,您可以在到达断点时从gdb提示符调用您自己的(或其他一些库函数),这些函数可以为您可视化图像缓冲区(可能在单独的窗口中)。 关于c++-可视化图像数据的调试器,我们在StackOverflow上找到一个类似的问题:

c++ - 使用 std::cout 一次而不是多次显示相同数量的数据是否更有效?

例如,像这样显示这些变量会不会更节省内存:std::cout而不是这个:std::cout当然,我并不是真的担心两行代码..但我正在努力学习更有效地编写代码谢谢 最佳答案 将其设为单个语句理论上会更快,因为编译器可以更自由地重新安排参数评估的顺序。但是,这是在谈论0.00000000000001%的差异,毫无意义。不要关心这个-瓶颈在控制台本身。无论如何,列对齐对于可读性非常有帮助,所以试试这个:std::cout或者这个:std::cout(我更喜欢第一个,因为我发现在我的文本编辑器中格式化更容易)。

c++ - boost::thread 和 std::thread 之间的区别

我有一个使用boost::thread的地方(例如使用boost::asio)std::vector>threads;for(std::size_ti=0;ithread(newboost::thread(boost::bind(&boost::asio::io_service::run,io_services_[i])));threads.push_back(thread);}如果我尝试将它与std:thread一起使用,我会得到编译错误:std::vectorthreads;for(std::size_ti=0;iioServices.size();++i){std::thread

c++ - 用 C/C++ 编写的通用代码完成框架

有没有用C/C++/C++11写的框架来写代码补全工具?或者可能有一些库允许Java或C++的代码完成(也用C++编写?)。我正在用C++为Java(不仅是Java)开发编写自定义IDE,我想以最好的方式向它添加代码完成支持,而无需重新发明weel;) 最佳答案 clang_complete是一个vim插件,用于准确完成C、C++、Objective-C和Objective-C++代码:https://github.com/Rip-Rip/clang_complete/它使用clang——一个用C++编写的开源C++编译器来完成这项

c++ - CreateFile 打开在另一个终端 session 中创建的 MS-DOS 设备

我有一个(某种过滤器)驱动程序,它应该与用户模式组件通信。它通过调用IoCreateDevice创建一个设备对象,然后通过IoCreateSymbolicLink为它创建一个所谓的MS-DOS符号链接(symboliclink),使用户可以访问它-模式代码(通过CreateFile)。这或多或少是一种标准技术。驱动程序创建一个形式为\DosDevices\mydevicename的符号链接(symboliclink),而用户模式代码打开一个名为\\.\mydevicename的文件。现在,当驱动程序在终端服务器session的上下文中创build备时,问题就开始了。创建的符号链接(sy

c++ - 嵌套的 std::function

有可能有一个std::function吗?返回std::function并使用与其他std::functions递归的各种函数,比如函数的函数?换句话说,我想将一组函数折叠成一个函数。例如脱离基础教程doublegenFunc(doublex,std::functionf){doubleres=f(x);returnres;}doublesquare(doublex){returnx*x;}doubledbl_sq(doublex){returnsquare(x*x);}我如何修改它以允许嵌套std::function电话? 最佳答案

c++ - 有效的 header 名称

我无法正确理解它们在以下文章中的含义:http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2004/n1566.htmItisinterestingtonotethatC89explicitlyallowedonlylettersinheaderandincludefilenames.C++addedunderscores,andC99addeddigits.Probablybothstandardsshouldallowboth.我在所有C和C++标准中发现了以下语句:ISO/IEC9899:19906.1.7HeadernamesS

c++ - 对角展平矩阵的邻域索引计算

我有一个二维矩阵存储在沿对角线的FlatBuffers中。例如,一个4x4矩阵的索引会像这样分散:0259148123711146101315使用这种表示,在给定原始索引和X/Y偏移量的情况下,计算相邻元素索引的最有效方法是什么?例如://returntheindexofaneighborgivenanoffsetintgetNGonalNeighbor(constsize_tindex,constintx_offset,constinty_offset){//...}//forthearrayabove:getNGonalNeighbor(15,-1,-1);//shouldretu

C++ 将 memcpy 转换为 std::copy

我想用“std::copy”替换我的“memcpy”,但我找不到传递参数的正确方法。我的旧memcpy代码是memcpy(&uFeatures.Features[0],&((char*)(m_pData))[iBytePos],iByteCount);我用std::copy尝试了各种方法,但都没有用。有人能帮忙吗? 最佳答案 从你的语法来看,它似乎是这样的。(假设Features[0]是char*,如果不是你需要转换(检查评论))std::copy(&uFeatures.Features[0],&uFeatures.Features

分配大型静态std :: unordered_map导致堆栈溢出

我正在创建一个静态std::unordered_map如下:auto*__epsgMap__=newstd::unordered_map({{3819,CRS::Info("HD1909","+proj=longlat+ellps=bessel+towgs84=595.48,121.69,515.35,4.115,-2.9383,0.853,-3.408+no_defs")},{3821,CRS::Info("TWD67","+proj=longlat+ellps=aust_SA+no_defs")},{3824,CRS::Info("TWD97","+proj=longlat+ellps=G